<!--
  ~ Licensed to the Apache Software Foundation (ASF) under one or more
  ~ contributor license agreements.  See the NOTICE file distributed with
  ~ this work for additional information regarding copyright ownership.
  ~ The ASF licenses this file to You under the Apache License, Version 2.0
  ~ (the "License"); you may not use this file except in compliance with
  ~ the License.  You may obtain a copy of the License at
  ~
  ~     http://www.apache.org/licenses/LICENSE-2.0
  ~
  ~ Unless required by applicable law or agreed to in writing, software
  ~ distributed under the License is distributed on an "AS IS" BASIS,
  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  ~ See the License for the specific language governing permissions and
  ~ limitations under the License.
  -->

<h2 mat-dialog-title>
    <div class="flex justify-between items-baseline">
        <div>
            {{ readonly ? 'Flow Analysis Rule Details' : 'Edit Flow Analysis Rule' }}
        </div>
        <div class="text-base">
            {{ formatType(request.flowAnalysisRule) }}
        </div>
    </div>
</h2>
<form class="flow-analysis-rule-edit-form" [formGroup]="editFlowAnalysisRuleForm">
    <context-error-banner [context]="ErrorContextKey.FLOW_ANALYSIS_RULES"></context-error-banner>
    <mat-tab-group [(selectedIndex)]="selectedIndex" (selectedIndexChange)="tabChanged($event)">
        <mat-tab label="Settings">
            <mat-dialog-content>
                <div class="dialog-tab-content flex gap-x-4">
                    <div class="w-full">
                        <mat-form-field>
                            <mat-label>Name</mat-label>
                            <input matInput formControlName="name" type="text" [readonly]="readonly" />
                        </mat-form-field>
                        <div class="flex flex-col mb-5">
                            <div>Id</div>
                            <div [copy]="request.flowAnalysisRule.id" class="tertiary-color font-medium">
                                {{ request.flowAnalysisRule.id }}
                            </div>
                        </div>
                        <div class="flex flex-col mb-5">
                            <div>Type</div>
                            <div class="tertiary-color font-medium">
                                {{ formatType(request.flowAnalysisRule) }}
                            </div>
                        </div>
                        <div class="flex flex-col mb-5">
                            <div>Bundle</div>
                            <div class="tertiary-color font-medium">
                                {{ formatBundle(request.flowAnalysisRule) }}
                            </div>
                        </div>
                    </div>
                    <div class="flex flex-col w-full">
                        <div>
                            <mat-form-field>
                                <mat-label>
                                    Enforcement Policy
                                    <i
                                        class="fa fa-info-circle"
                                        nifiTooltip
                                        [tooltipComponentType]="TextTip"
                                        tooltipInputData="The enforcement policy of the flow analysis rule."></i>
                                </mat-label>
                                <mat-select formControlName="enforcementPolicy">
                                    @for (option of strategies; track option) {
                                        <mat-option
                                            [value]="option.value"
                                            [disabled]="readonly"
                                            nifiTooltip
                                            [tooltipComponentType]="TextTip"
                                            [tooltipInputData]="option.description"
                                            [delayClose]="false">
                                            {{ option.text }}
                                        </mat-option>
                                    }
                                </mat-select>
                            </mat-form-field>
                        </div>
                    </div>
                </div>
            </mat-dialog-content>
        </mat-tab>
        <mat-tab label="Properties">
            <mat-dialog-content>
                <div class="dialog-tab-content flex gap-x-3">
                    <property-table
                        class="w-2/3"
                        formControlName="properties"
                        [createNewProperty]="createNewProperty"
                        [createNewService]="createNewService"
                        [propertyHistory]="request.history"
                        [supportsParameters]="false"
                        [goToService]="goToService">
                    </property-table>
                    <property-verification
                        class="w-1/3"
                        [disabled]="readonly"
                        [isVerifying]="(propertyVerificationStatus$ | async) === 'loading'"
                        [results]="propertyVerificationResults$ | async"
                        (verify)="verifyClicked(request.flowAnalysisRule)"></property-verification>
                </div>
            </mat-dialog-content>
        </mat-tab>
        <mat-tab label="Comments">
            <mat-dialog-content>
                <div class="dialog-tab-content">
                    <mat-form-field>
                        <mat-label>Comments</mat-label>
                        <textarea
                            matInput
                            formControlName="comments"
                            type="text"
                            rows="10"
                            [readonly]="readonly"></textarea>
                    </mat-form-field>
                </div>
            </mat-dialog-content>
        </mat-tab>
    </mat-tab-group>
    @if ({ value: (saving$ | async)! }; as saving) {
        <mat-dialog-actions align="end">
            @if (readonly) {
                <button mat-flat-button mat-dialog-close>Close</button>
            } @else {
                <button mat-button mat-dialog-close>Cancel</button>
                <button
                    [disabled]="
                        !editFlowAnalysisRuleForm.dirty ||
                        editFlowAnalysisRuleForm.invalid ||
                        saving.value ||
                        editFlowAnalysisRuleForm.pending
                    "
                    type="button"
                    (click)="submitForm()"
                    mat-flat-button>
                    <span *nifiSpinner="saving.value">Apply</span>
                </button>
            }
        </mat-dialog-actions>
    }
</form>
